//给定两个字符串 s 和 p，找到 s 中所有 p 的 变位词 的子串，返回这些子串的起始索引。不考虑答案输出的顺序。
//
// 变位词 指字母相同，但排列不同的字符串。
//
//
//
// 示例 1:
//
//
//输入: s = "cbaebabacd", p = "abc"
//输出: [0,6]
//解释:
//起始索引等于 0 的子串是 "cba", 它是 "abc" 的变位词。
//起始索引等于 6 的子串是 "bac", 它是 "abc" 的变位词。
//
//
// 示例 2:
//
//
//输入: s = "abab", p = "ab"
//输出: [0,1,2]
//解释:
//起始索引等于 0 的子串是 "ab", 它是 "ab" 的变位词。
//起始索引等于 1 的子串是 "ba", 它是 "ab" 的变位词。
//起始索引等于 2 的子串是 "ab", 它是 "ab" 的变位词。
//
//
//
//
// 提示:
//
//
// 1 <= s.length, p.length <= 3 * 10⁴
// s 和 p 仅包含小写字母
//
//
//
//
// 注意：本题与主站 438 题相同： https://leetcode-cn.com/problems/find-all-anagrams-in-a-
//string/
// Related Topics 哈希表 字符串 滑动窗口 👍 15 👎 0

package leetcode.editor.cn;

import java.util.ArrayList;
import java.util.List;

@SuppressWarnings("all")
//Java：字符串中的所有变位词
public class 字符串中的所有变位词 {
    public static void main(String[] args) {
        Solution solution = new 字符串中的所有变位词().new Solution();
        // TO TEST
    }

    //leetcode submit region begin(Prohibit modification and deletion)
    class Solution {
        public List<Integer> findAnagrams(String s, String p) {

            ArrayList<Integer> res = new ArrayList<>();
            if (p.length() > s.length())
                return res;


            int[] count = new int[26];
            for (int i = 0; i < p.length(); i++) {
                count[p.charAt(i) - 'a']++;
            }

            int left = 0, right = 0;

            while (left <= right && right < s.length()) {

                int ch = s.charAt(right) - 'a';
                count[ch]--;
                if (right >= p.length() - 1) {
                    if (check(count)) {
                        res.add(left);
                    }
                    count[s.charAt(left) - 'a']++;
                    left++;

                }

                right++;
            }


            return res;
        }

        private boolean check(int[] count) {

            for (int i : count) {
                if (i > 0)
                    return false;
            }
            return true;
        }
    }
//leetcode submit region end(Prohibit modification and deletion)


}
